package org.cable.shop.config;

import lombok.Data;
import org.springframework.amqp.core.Binding;
import org.springframework.amqp.core.Binding.DestinationType;
import org.springframework.amqp.core.Exchange;
import org.springframework.amqp.core.Queue;
import org.springframework.amqp.core.TopicExchange;
import org.springframework.amqp.support.converter.Jackson2JsonMessageConverter;
import org.springframework.amqp.support.converter.MessageConverter;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

import java.util.HashMap;
import java.util.Map;

/**
 * 小滴课堂,愿景：让技术不再难学 * 自定义消息队列配置， * 发送 关单消息-》延迟exchange-》order.close.delay.queue-》死信exchange-》order.close.queue *
 *
 * @Description
 * @Author 二当家小D
 * @Remark 有问题直接联系我，源码-笔记-技术交流群
 * @Version 1.0
 **/

@Configuration
@Data
public class RabbitMQConfig {

	/**
	 * 交换机
	 */
	private String orderEventExchange = "order.event.exchange";

	/**
	 * 延迟队列，不能被消费者监听
	 */
	private String orderCloseDelayQueue = "order.close.delay.queue";

	/**
	 * 关单队列，延迟队列的消息过期后转发的队列，用于被消费者监听
	 */
	private String orderCloseQueue = "order.close.queue";

	/**
	 * 进入到延迟队列的routingKey
	 */
	private String orderCloseDelayRoutingKey = "order.close.delay.routing.key";

	/**
	 * 进入死信队列的routingKey，消息过期进入死信队列的key
	 */
	private String orderCloseRoutingKey = "order.close.delay.key";

	/**
	 * 过期时间，毫秒单位，临时改为5分钟过期
	 */
	private Integer ttl = 1000 * 60 * 5;

	/**
	 * 消息转换器
	 *
	 * @return
	 */
	@Bean
	public MessageConverter messageConverter() {
		return new Jackson2JsonMessageConverter();
	}

	/**
	 * 创建交换机，topic类型，一般一个业务一个交换机
	 *
	 * @return
	 */
	@Bean
	public Exchange orderEventExchange() {
		return new TopicExchange(orderEventExchange, true, false);
	}

	/**
	 * 给延迟队列(配置死信交换机) 延迟队列中的消息超过ttl时间进入到死信交换机中
	 *
	 * @return
	 */
	@Bean
	public Queue orderCloseDelayQueue() {
		Map<String, Object> args = new HashMap<>(3);
		args.put("x-dead-letter-exchange", orderEventExchange);
		args.put("x-dead-letter-routing-key", orderCloseRoutingKey);
		args.put("x-message-ttl", ttl);
		return new Queue(orderCloseDelayQueue, true, false, false, args);

	}

	/**
	 * 死信队列，是一个普通队列，用于被监听
	 *
	 * @return
	 */
	@Bean
	public Queue orderCloseQueue() {
		return new Queue(orderCloseQueue, true, false, false);
	}

	/**
	 * 第一个队列 即延迟队列和交换机建立绑定关系
	 *
	 * @return
	 */
	@Bean
	public Binding orderCloseDelayBinding() {
		return new Binding(orderCloseDelayQueue,
		                   Binding.DestinationType.QUEUE, orderEventExchange, orderCloseDelayRoutingKey, null
		);
	}

	/**
	 * 死信队列和死信交换机简历绑定关系
	 *
	 * @return
	 */
	@Bean
	public Binding orderCloseBinding() {

		return new Binding(orderCloseQueue,
		                   Binding.DestinationType.QUEUE, orderEventExchange, orderCloseRoutingKey, null
		);
	}



	/**================================订单支付成功配置=============================>*/

	/**
	 * 更新订单队列
	 */
	private String orderUpdateQueue = "order.update.queue";

	/**
	 * 订单发放流量包队列
	 */
	private String orderTrafficQueue ="order.traffic.queue";

	/**
	 * 微信回调发送通知的routing key [发送消息用]
	 */
	private String orderUpdateTrafficRoutingKey ="order.update.traffic.routing.key";

	/**
	 *topic类型的 用于绑定订单队列和交换机的
	 */
	private String orderUpdateBindingKey = "order.update.*.routing.key";

	/**
	 * topic类型的 用于绑定流量包发送队列和交换机
	 */
	private String orderTrafficBindingKey = "order.*.traffic.routing.key";

	/**
	 * 订单更新队列 和 交换机绑定关系
	 * @return
	 */
	@Bean
	public Binding orderUpdateBinding(){
		return new Binding(orderUpdateQueue, DestinationType.QUEUE,orderEventExchange,orderUpdateBindingKey,null );
	}

	/**
	 * 发放流量包队列和交换机建立绑定关系
	 * @return
	 */
	@Bean
	public Binding orderTrafficBinding(){
		return new Binding(orderTrafficQueue, DestinationType.QUEUE,orderEventExchange,orderTrafficBindingKey,null );
	}

	/**
	 * 更新订单队列,普通队列,用于被监听消费
	 * @return
	 */
	@Bean
	public Queue orderUpdateQueue(){
		return new Queue(orderUpdateQueue,true,false,false);
	}

	/**
	 * 发放流量包队列
	 * @return
	 */
	@Bean
	public Queue orderTrafficQueue(){
		return new Queue(orderTrafficQueue,true,false,false);
	}

}
